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Method and System for Collecting Traffic Data in a Computer Network 

This application claims the benefit of U.S. Provisional Application No. 
60/251,81 1, filed December 7, 2000, which is hereby incorporated by reference. 

Background 

Traffic Engineering 

Many network operators are presented with the problem of efficiently allocating 
bandwidth in response to demand — efficiency both in terms of the amount of time that it 
takes the allocation to occur and the amount of resources that need to be allocated. One 
current solution is to sufficiently overprovision bandwidth, so that (1) provisioning only 
needs to be adjusted on a periodic basis (e.g., monthly/quarterly) and (2) unexpected 
fluctuations in the amount of traffic submitted to the network do not result in the 
"congestive collapse" of the network. When provisioning optical wavelengths, for 
example, carriers simply accept that they must greatly overprovision, adding more 
equipment to light up new fiber when the fiber has reached only a small fraction of its 
total capacity. There are some network planning and analysis tools that are available to 
carriers, but these are off-line tools. Carriers with optical networks are testing optical 
switches with accompanying software that provides point-and-click provisioning of 
lightpaths, but decisions on which lightpaths to set up or tear down are still being made 
off-line, and network-wide optimization or reconfiguration is still not possible with these 
tools. In other words, these tools do little to provide more efficient network 
configurations - carriers are still left with fairly static network architectures. 

The use of optical switches allows the provisioning of end-to-end all optical paths. 
In such a network, Electrical-to -Optical and Optical-to-Electrical conversion is only done 
at the ingress and egress network elements of the optical network, rather than at every 
network element throughout the path. Reducing Optical-to-Electrical-to-Optical 
conversion (OEO) is advantageous because the equipment needed to do OEO conversion 
and the associated electrical processing is expensive, requiring vast amounts of 
processing and memory. This expense is only expected to increase as data rates increase 



to 10 Gb/s and beyond. Therefore it is expected that carriers will migrate toward an all- 
optical core. 

At present, carriers cannot perform automatic provisioning or automated traffic 
engineering in their networks. The inability to automate these processes manifests itself 
in several ways. First of all, carriers frequently require 30 to 60 days to provision a 
circuit across the country from New York to Los Angeles, for example. The manual 
nature of this process means that it is not only costly in terms of manual labor and lost 
revenue, but it is also error prone. Secondly, as mentioned above, because carriers cannot 
provision their networks on demand, they often over-engineer them (often by a factor of 2 
or 3) so that they can accommodate traffic bursts and an increase in the overall traffic 
demand placed on the network over a period of at least several months. This results in 
significant extra equipment cost, as well as "lost bandwidth" --- bandwidth that has been 
provisioned but frequently goes unused. Finally, because traffic engineering and 
provisioning are manual processes, they are also error-prone. Network operators 
frequently mis-configure network elements resulting in service outages or degradation 
that again costs carriers significant revenue. 

Several traffic engineering systems have been offered in the past. One such 
system is known as "RATES" and is described in P. Aukia, M. Kodialam, et al., 
"RATES: A Server for MPLS Traffic Engineering," IEEE Network Magazine, 
March/April 2000, pp. 34-41. RATES is a system by which explicit requests for network 
circuits of stated bandwidth can be automatically routed through the network. RATES 
does not provide a way to reroute existing traffic, nor does it have a way to handle traffic 
for which an explicit request was not made. Further, RATES is unable to use traffic 
patterns to drive the routing or rerouting of traffic. 

U.S. Patent No. 6,021,1 13 describes a system for the pre-computation of 
restoration routes, primarily for optical networks. This system is explicitly based on the 
pre-computation of routes and does not compute routes in reaction to a link failure. 
Further, this system carries out the computation of restoration routes, which are routes 
that can be used to carry the network's traffic if a link should fail, prior to the failure of 
the link, and is not based on observed or predicted traffic patterns. 



U.S. Patent No. 6,075,631 describes an algorithm for assigning wavelengths in a 
WDM system such that the newly-assigned wavelengths do not clash with existing 
wavelength assignments and then transitioning the topology between the old state and the 
new state. The assignment of wavelengths is not made based on any kind of observed or 
predicted traffic pattern, and the algorithm only allocates resources in units of individual 
wavelengths. 

Network Monitoring and Statistics Collection 

Network monitoring and statistics collection is an important component of a 
carrier's network. Among other benefits, it allows network operators to make traffic 
engineering and resource provisioning decisions, to select the appropriate configuration 
for their network elements, and to determine when and if network elements should be 
added, upgraded, or reallocated. Presently, network operators deploy a multiplicity of 
systems in their networks to perform monitoring and data collection functions. 
Equipment providers {e.g., Cisco, Fujitsu, etc.) each provide systems that manage their 
own network elements (e.g., IP router, SONET ADM, ATM Switch, Optical Cross- 
Connect, etc.). As a result, network operators are forced to operate one network 
monitoring/management system for each of the different vendor's equipment that is 
deployed in their network. Furthermore, if a variety of equipment types are obtained from 
each vendor, the network operator may need to have more than one monitoring system 
from a particular equipment vendor. For example, if both IP routers and SONET ADMs 
are purchased from the same vendor, it is possible that the network operator will have to 
use one monitoring system for the routers and one for the ADMs. 

To date, no one has provided a hierarchical system that allows a network operator 
to monitor/collect statistics from all types of network equipment. Neither has anyone 
provided a system that allows a network operator to monitor/collect statistics from all 
types of networking equipment using a multiplicity of protocols. Providing an integrated 
system that interacts with multiple vendor's equipment and multiple types of equipment 
from each vendor would be a tremendous value-add to carriers, allowing them to get a 
complete picture of their network and its operation, rather than many fragmented or 
partial snapshots of the network. A system that can interact with network elements using 
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a variety of protocols and that can monitor, collect statistics from, manage, or configure 
network elements from a variety of equipment vendors has not been provided to date. 

Additionally, network operators (carriers) are increasingly finding that they need 
efficient ways to monitor and collect statistics from their network in order to verify that 

5 their network is performing adequately and to determine how best to provision their 

network in the future. Collecting and using network and traffic statistics from various 
network elements (e.g., routers, switches, SONET ADMs, etc.) is a very difficult 
problem. Carriers first need to determine what metrics are of interest to them, and then 
they must decide what data to collect and on what schedule to collect it so that they have 

10 these metrics to a useful degree of accuracy. Routers are being deployed with OC-192 or 

faster interfaces. The volume of data flowing through these routers makes it impractical 
to log or store information about all of the traffic flows being serviced by a particular 

2 router. Providing a statistics collection system that can filter and aggregate information 

J1 from network elements, reducing the amount of raw data that needs to be stored by the 

jfS carrier, will be increasingly important. 

[y Network Reconfiguration 

= : There is no system today that actually implements automatic network 

5 reconfiguration. While some systems, such as the NetMaker product by MAKE Systems, 

!^ can produce MPLS configuration files/scripts for certain routers, no automation is 

jP> provided. Additionally, the method and system for monitoring and manipulating the flow 

of private information on public networks described in U.S. Patent No. 6,148,337 and the 
method and system for automatic allocation of resources in a network described in U.S. 
Patent No. 6,009,103 do not disclose automatic network reconfiguration. 

Summary 

25 By way of introduction, the preferred embodiments described herein provide a 

system and method for collecting traffic data in a computer network. In one preferred 
embodiment, a computer network is provided with a plurality of network elements each 
operating with a different protocol. A protocol with which to communicate with one of 
the network elements is determined, and traffic data is collected from the network 
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element using the determined protocol Other preferred embodiments are provided, and 
any or all of the preferred embodiments described herein can be used alone or in 
combination with one another. These preferred embodiments will now be described with 
reference to the attached drawings. 

5 Brief Description of the Drawings 

Figure 1 is an illustration of a computer network of a preferred embodiment 
comprising a plurality of nodes. 

Figure 2 is a block diagram of a preferred embodiment of the traffic management 

system. 

1 o Figure 3 is an illustration of a traffic management system of a preferred 

embodiment. 

2 Figure 4 is a flow chart illustrating the chronological operation of a traffic 
J1 management system of a preferred embodiment. 

;*? Figure 5 is a flow chart illustrating how a TMS Algorithm of a preferred 

|| embodiment can be implemented. 

« Figure 6 is an illustration of a computer network of a preferred embodiment in 

2 which a plurality of TMS Statistics Collection Servers in a respective plurality of points 

|" of presence (POPs) are coupled with a central TMS Statistics Repository. 

p Figure 7 is an illustration of a TMS Statistics Repository of a preferred 

20 embodiment. 

Figure 8 is block diagram of a TMS Statistics Collection Server of a preferred 
embodiment. 

Figure 9 is an illustration of a traffic management system of a preferred 
embodiment and show details of a TMS Signaling System. 
25 Figure 1 0 is a block diagram of a TMS Signaling Server of a preferred 

embodiment having protocol-specific modules. 

Figure 1 1 is an illustration of a set of sub-modules that allow a TMS Statistics 
Collection Server to communicate with different types of network elements. 
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Detailed Description of the Presently 
Preferred Embodiments 

The following articles discuss general traffic engineering and network concepts 
and are hereby incorporated by reference: "Traffic Engineering for the New Public 
Network" by Chuck Semeria of Juniper Networks, Publication No. 200004-004 
September 2000, pages 1-23; "NetScope: Traffic Engineering for IP Networks " 
Feldmann et al, IEEE Network, March/April 2000, pages 11-19; "MPLS and Traffic 
Engineering in IP Networks," Awduche, IEEE Communications Magazine, December 
1999, pages 42-47; "Measurement and Analysis of IP Network Usage and Behavior," 
Caceres et al, IEEE Communications Magazine, May 2000, pages 144-151; and 
"RATES: A Server for MPLS Traffic Engineering " P. Aukia et al, IEEE Network 
Magazine, March/April 2000, pages 34-41. The following U.S. patents also relate to 
computer networks and are hereby incorporated by reference; 6,148,337; 6,108,782; 
6,085,243; 6,075,631; 6,073,248; 6,021,113; 6,009,103; 5,974,237; 5,948,055; 5,878,420; 
5,848,244; 5,781,735; and 5,315,580. 
Traffic Engineering Embodiments 

Turning now to the drawings, Figure 1 is an illustration of a computer network 
100 of a preferred embodiment comprising a plurality (here, seven) of locations 1 10, 
which are also known as Points of Presence (POPs) or nodes, each comprising at least 
one network element. As used herein, the term "network element" is intended to broadly 
refer to any device that connects to one or more network elements and is capable of 
controlling the flow of data through the device. Examples of network elements include, 
but are not limited to, routers, optical routers, wavelength routers, label switched routers 
(LSR), optical cross-connects, optical and non-optical switches, Synchronous Optical 
Network (SONET) Add-Drop Multiplexers (ADMs), and Asynchronous Transfer Mode 
(ATM) switches. 

The data exchanged between nodes is preferably in digital form and can be, for 
example, computer data (e.g., email), audio information (e.g., voice data, music files), 
and/or video information, or any combination thereof. Data, which is also referred to as 
network traffic, is communicated between the nodes 1 10 of the network 100 via a path. 



As used herein, the term "path" is intended to refer to the way in which data is directed 
through one or more network elements. A path can, for example, be represented by 
protocol labels, such as those used within the Multi-Protocol Label Switching (MPLS) 
framework (used on Packet-Switch Capable (PSC) interfaces), time slots (used on Time- 
Division Multiplex Capable (TDMC) interfaces), wavelengths (used on Lambda Switch 
Capable (LSC) interfaces), and fibers (used on Fiber Switch Capable (FSC) interfaces). 
Paths can have other representations. Accordingly, a path can be an explicit labeling of 
the traffic (e.g., Label Switched Paths (LSPs)), the creation of a forwarding schedule in 
the network elements (e.g., a Time Division Multiplexing (TDM) switching table), and 
lightpaths. For simplicity, the network used to illustrate these preferred embodiments has 
a fixed physical connectivity (topology), and the path between nodes takes the form of 
label-switched paths (LSPs). Of course, other network topology and provisioning 
systems can be used, and the claims should not be read to include these elements unless 
these elements are explicitly recited therein. 

Figure 1 shows the nodes 1 10 of the network 100 coupled with a network (traffic) 
management system 120. As used herein, the term "coupled with" means directly 
coupled with or indirectly coupled with through one or more named or unnamed 
components. In this preferred embodiment, the traffic management system 120 
automatically directs data in the computer network 100 (e.g. , automatically provisions 
paths through the network) in response to traffic demands. As used herein, the term 
"automatically" means without human intervention (e.g., without the intervention of a 
network operator). Traffic demands can be determined by observations of existing traffic 
patterns and/or by explicit user requests to the network via a User-Network-Interface 
(UNI) (e.g., Optical Network Interface, OIF 2000. 125). Traffic demands can also be 
determined by predicting future traffic patterns based on observed traffic patterns or on 
notification of traffic demands via a policy system such as the Common Object Policy 
Service (COPS). One or more ways of determining traffic demands can be used. 
Although not required, the traffic management system can monitor the traffic patterns in 
the automatically-provisioned path and automatically provision yet another path based on 
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the monitored traffic demands. This provides a feedback functionality that repeatedly and 
dynamically provisions paths in the network. 

The traffic management system can take any suitable form, such as one or more 
hardware (analog or digital) and/or software components. For example, the traffic 
management system can take the form of software running on one or more processors. 
The traffic management system can be distributed among the nodes in the network or 
implemented at a central location. A traffic management system having a logical central 
control as shown in Figure 1 will be used to illustrate these preferred embodiments. 

Turning again to the drawings, Figure 2 is a block diagram of one presently 
preferred embodiment of the traffic management system (TMS). In this preferred 
embodiment, the traffic management system comprises a TMS Algorithm 200. The TMS 
Algorithm 200, which can be implemented with hardware and/or software, receives 
inputs that represent the traffic demand on the network 210. With these inputs and with 
knowledge of network topology and policy information, the TMS Algorithm 200 outputs 
network element configurations to automatically direct data based on the traffic demand. 
For example, the TMS can collect traffic information from all edge routers and switches 
in the network 210, predict bandwidth needs throughout the network 210, and send 
control information back to the network elements to reconfigure the network 210 to alter 
the forwarding of data so that network resources are better utilized (i.e., optimally 
utilized) based on the traffic demand on the network 210. 

As shown in Figure 2, one input to the TMS Algorithm 200 can be explicit 
allocations requests 220 made by customers of the operator's network 210 and/or service 
level agreements (SLAs) 230. Examples of methods for requesting service include the 
User Network Interface defined by the Optical Internetworking Forum (OIF) and the 
Resource Reservation Protocol (RSVP) defined by the Internet Engineering Task Force 
(IETF). The COPS system, also defined by the IETF, enables the carrier to enter into a 
database the policies the carrier wants enforced for the network. Some classes of these 
policies specify services the network should provide, and so these policies reflect the 
requests for service made to the carrier and can be treated by the TMS as requests for 
service. In many situations, however, there will not be an explicit request made for 
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service for some or all of the data carried by the network. In these cases, the traffic 
demand is determined by observation of the existing traffic or statistics and/or predictions 
of future traffic demand based on those statistics. Figure 2 shows traffic predictions 
and/or statistics being provided to the TMS Algorithm 200 through a component labeled 
TMS Statistics Repository 240 and shows network element configurations being 
outputted through a component labeled TMS Signaling System 250. It should be noted 
that the input and output of the TMS Algorithm 200 can be received from and provided to 
the operator's network 210 without these components, which will be described in detail 
below. 

Figure 3 provides an illustration of one presently preferred implementation of a 
traffic management system. As shown in Figure 3, the operator's network comprises a 
plurality of network elements 303 located at Points of Presence (POPs) or nodes 300, 
301 , and 302. In the embodiment shown in Figure 3, there are three routers R in each of 
the three POPs 300, 301 , 302. It should be understood that a network can have more or 
fewer network elements and POPs and that the network elements are not necessarily 
routers. In this preferred embodiment, the traffic management system comprises a 
number of sub-systems: a plurality of TMS Statistics Collection and Signaling Servers 
304, 305, 306, a TMS Statistics Repository 310, a TMS Algorithm 320, and a TMS 
Signaling System 330. It should be noted that while each TMS Statistics Collection and 
Signaling Server 304, 305, 306 is shown as a single entity, the TMS Statistics Collection 
and Signaling Server 304, 305, 306 can be implemented as two separate entities: a 
statistics collection server and a signaling server. While the TMS Statistics Collection 
and Signaling Servers 304, 305, 306 will be described in this section as one entity that 
performs both the statistics collection and signaling functions, in other sections of this 
document, the statistics collection and signaling functionality is distributed between two 
or more servers. Also, while Figure 3 shows the TMS Statistics Collection and Signaling 
Servers 304, 305, 306 distributed throughout the network with one TMS Statistics 
Collection and Signaling Server 304, 305, 306 located at each POP 300, 301, 302, other 
arrangements are possible. 
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Each TMS Statistics Collection and Signaling Server 304, 305, 306 connects to 
the network elements (in this embodiment, routers R) within its local POP and collects 
and processes traffic data from the network elements. This information is fed back 
through the network to the TMS Statistics Repository 310, where the information is 
stored. The TMS Algorithm 320 processes the collected statistics stored in the TMS 
Statistics Repository 3 10 and determines the optimal network configuration. As 
mentioned above, the TMS Algorithm 320 can operate with traffic for which a request for 
service has been made in addition to traffic offered without a request by adding the 
requested demands to the demand determined by observing the pattern of traffic that is 
not covered by a request. Communication with the TMS Statistics Repository 3 10 can be 
via an "out-of-band" communication channel, or alternatively, an in-band channel within 
the network. Once the TMS Algorithm 320 determines the optimal network 
configuration, the TMS Signaling System 330 sends the optimal network configuration to 
each TMS Statistics Collection and Signaling Server 304, 305, 306 by generating the 
appropriate configuration information for each network element (in this embodiment, the 
routers R) and distributes this information to each TMS Statistics Collection and 
Signaling Server 304, 305, 306. The TMS Statistics Collection and Signaling Servers 
304, 305, 306 then distribute this information to their respective routers R, thereby 
allowing the optimal network configuration determined by the TMS Algorithm 320 to be 
implemented. 

Figure 4 is a flow chart showing the chronological operation of the Traffic 
Management System of Figure 3. First, the TMS Statistics Collection and Signaling 
Servers 304, 305, 306 instruct the routers R to collect specific traffic information (act 
400). The TMS Statistics Collection and Signaling Servers 304, 305, 306 receive traffic 
information from the routers R (act 410) and process the traffic information (act 420). 
The TMS Statistics Collection and Signaling Servers 304, 305, 306 then send the 
information to the TMS Statistics Repository 310 (act 430). The TMS Algorithm 320 
creates a traffic demand matrix using information stored in the TMS Statistics Repository 
310 (act 440) and uses the traffic demand matrix to determine an optimal network 
configuration (act 450) in conjunction with the Network Topology Information. The 
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TMS Signaling System 330 receives the network configuration from the TMS Algorithm 
320 (act 460). After the TMS Statistics Collection and Signaling Servers 304, 305, 306 
receive the network configuration from the TMS Signaling System 330 (act 470), the 
TMS Statistics Collection and Signaling Servers 304, 305, 306 configure each router R as 
appropriate (act 480). When the configuration is done (act 490), the TMS Statistics 
Collection and Signaling Servers 304, 305, 306 again receive traffic information from the 
routers R (act 410), and the process described above is repeated. 

As described above, one feature of this system is the real-time feedback loop. 
Measurements/statistics collected from the network (in addition to specific SLAs or 
requests from users) are repeatedly analyzed by the TMS Algorithm 320, which then 
adjusts the network configuration. The actual running of the TMS Algorithm 320 can be 
periodic (as shown in Figure 4), or it can be event driven (e.g., when a new SLA is added 
to the system). Table 1 shows an example of the type of data in the records obtained from 
the network elements by the TMS Statistics Collection and Signaling Servers 304, 305, 
306. 



Table 1 



Contents 


Description 


Srcaddr 


Source IP address 


dstaddr 


Destination IP address 


nexthop 


IP address of next hop router 


input 


SNMP index of input interface 


output 


SNMP index of output interface 


dPkts 


Packets in the flow 


dOctets 


Total number of Layer 3 bytes in the packets of the flow 


First 


SysUptime at start of flow 


Last 


SysUptime at the time the last packet of the flow was received 


srcport 


TCP/UDP source port number or equivalent 


dstport 


TCP/UDP destination port number or equivalent 


padl 


Unused (zero) bytes 


tcp_flags 


Cumulative OR of TCP flags 


prot 


IP protocol type (for example, TCP = 6; UDP = 17) 


tos 


IP type of service (ToS) 


src_as 


Autonomous system number of the source, either origin or peer 


dst_as 


Autonomous system number of the destination, either origin or peer 
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src_mask 


Source address prefix mask bits 


dst__mask 


Destination address prefix mask bits 


pad2 


Unused (zero) bytes 



Figure 5 shows one instance of how the TMS Algorithm 320 can be implemented. 
The algorithm is run every AT time period where AT is chosen such that it is greater than 
the time required to collect traffic information, process it, find new paths, and send 
control information to the routers or switches. The result of the algorithm's execution is 
a series of paths (P) that is to be set up to allow the predicted traffic to flow. In practice, 
the algorithm does not necessarily need to be periodic, and in fact can be triggered, for 
example, by a sufficiently large change in the traffic patterns. 

Every time period, the algorithm, using traffic statistics collected from the 
network, determines all ingress-egress traffic flows, and uses this data to estimate the 
needed bandwidth during the next time period. The estimated bandwidth is also known 
as the traffic demand matrix, each element in the matrix representing the bandwidth 
demand between a network ingress point (in) and a network egress point (out). In act 
501, the demand matrix is computed by taking the mean and variation of the traffic 
demand over the previous ten time periods and predicting the demanded traffic D in;0 ut as 
the mean plus three times the standard deviation. Other methods may be used such as 
using maximum load over observation period, max+variance, mean+ct* variance, 
projected trend, or mean. 

The non-zero elements of the demand matrix are then sorted in descending order 
(act 502). The elements, called flows, are placed on a stack and processed one at a time, 
starting with the largest first (act 504). Given each flow, the cost associated with putting 
that flow on a link between two nodes is computed (act 506). For each link in the 
network bounded by routers i and j, Cost(i,j,F) is computed as: 
Cost(i,j,F) = l/(C g - D m , 0 ut), for Q,j - D in , 0 ut > 0 
Cost(i j,F) = infinity, for C i?J - D in;0 ut <= 0 
• C„j is the capacity of each link (i,j) 
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• 1 / (C„j - D in! out) is the inverse of the link capacity minus the bandwidth 
requirement (demand) of the flow, F. 

The initial capacity allocations for each link (i,j) can be found, for example, by 
running a routing protocol, such as OSPF-TE (Open Shortest Path First with Traffic 
Engineering extensions), that discovers not only the network topology, but also the 
bandwidth of each link. 

In act 507, a weight matrix W is then instantiated, such that element (i,j) of the 
matrix W is Cost(i,j,F). Wg is then used to determine how to route each flow (F), by 
running a single source shortest path search on W from the ingress point of F (in) to the 
egress point of F (out) (act 508). Single source shortest path searches are well understood 
by those skilled in the art. The result of this search is the path, P. The intermediate states 
are saved into an array of partial results (act 509), and the residual capacity for each link 
(act 510), Cj,j is computed by removing the traffic demand of F from links (i j) along the 
shortest path P. That is C,j = Cg - Di n , 0 ut. 

Act 5 1 1 checks if all flows have been processed. If not, the next flow is popped 
off the stack and analyzed (act 504) as described above. Otherwise the algorithm waits 
for the end of the time interval, AT, and begins the entire network path optimization 
process again (act 501). It may be the case that there is a flow, F, that cannot be allocated 
a path because all possible paths in the network have been exhausted. In this case, the 
system can terminate and report the remaining flows that it is unable to allocate. In 
another embodiment, the system can backtrack to an earlier round, reorder the list, and 
resume running in order to find a more optimal solution. Earlier rounds are stored in the 
arrays SavedCapacity, AllocatedFlow, and ResultingPath (act 509). 

Many other algorithms for computing the paths over which traffic demands should 
be routed are possible. Which algorithm will perform best depends on the conditions in 
the particular network to which this preferred embodiment is applied. The network 
engineer deploying this preferred embodiment may prefer to try the several algorithms 
described here and their variants and select the algorithm that performs best in their 
network. Alternatively, the system can be configured to automatically try several 
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algorithms and then select the algorithm that produces the result that is able to satisfy the 
maximum number of flows. 

The problem of computing paths to carry traffic demands can be reduced to the 
well known problem of bin-packing, for which many exact and approximate solutions are 
known. By reducing the network routing problem to the equivalent bin-packing problem 
and then solving the bin-packing problem using any known method, the network routing 
problem will also be solved. 

Other classes of algorithms are also suitable. Examples of such algorithms 
follow. First, express the network optimization problem as a linear program where the 
traffic to be forwarded over each possible path through the network is represented as a 
variable (PI, P2,. Pn) for each path 1 to n. Constraint equations are written for each 
link to limit the sum of traffic flowing on the paths that traverse the link to the capacity of 
the link. The objective function is written to maximize the sum of traffic along all paths. 
Solving such a linear program is a well known process. Second, represent the 
configuration of the network as a multi-dimensional state variable, write the objective 
function to maximize the sum of the traffic carried by the network, and use genetic 
algorithms to find an optimal solution. Techniques for representing a network as a state 
variable and the use of a genetic algorithm can be adapted by one skilled in the art from 
the method in A Spare Capacity Planning Methodology for Wide Area Survivable 
Networks, by Adel Al-Rumaih, 1999, which is hereby incorporated by reference. Third, 
after representing the network as described in (2) above, using simulated annealing to 
find the optimal solution. 

Once the path descriptions have been computed by the algorithm, the network is 
configured to implement these paths for the traffic. This can be achieved by converting 
the path descriptions into MPLS Label Switched Paths and then installing MPLS 
forwarding table entries and traffic classification rules into the appropriate network 
elements. As described earlier, it can also be achieved via configuring light paths or by 
provisioning any other suitable type of path. 

One method to convert the path descriptions, P, determined by the algorithm into 
MPLS table entries is for the TMS software to keep a list of the labels allocated on each 
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link in the network. For each link along each path, the software chooses an unallocated 
label for the link and adds it to the list of allocated labels. For routers on either end of the 
link, the TMS Signaling System (via the TMS Signaling Servers) creates an MPLS 
forwarding table entry that maps an incoming label from one link to an outgoing label on 
another link. Installing the resulting MPLS forwarding table configurations manually into 
a router is a well-understood part of using MPLS. Another method for the TMS Signaling 
System to create the paths uses either RSVP-TE or LDP to automatically set up MPLS 
label bindings on routers throughout the network. 

In this embodiment, the MPLS table installation is automated using standard inter- 
process communication techniques by programming the TMS Signaling System to send 
the network element configurations commands over the network via SNMP or via a 
remote serial port device plugged into the network element's console port. Remote serial 
port devices acceptable for this purpose are commercially available. MPLS table 
configurations are loaded into all network elements simultaneously at the end of the AT 
time period. Since all TMS Signaling Servers running the traffic management software 
are synchronized at T=0 ? all control information is loaded into the network elements 
synchronously. As another possibility, the system can use the distribution system as 
taught in U.S. Patent 5,848,244. 

The TMS described above is not limited to using MPLS to construct paths, and it 
can manage many types of network elements beyond LSRs, for example, Lambda 
Routers, Wavelength Routers, and Optical Cross Connects (OXCs). A Lambda Router is 
a photonic switch capable of mapping any wavelength on an incoming fiber to any 
wavelength on an outgoing fiber. That is, a lambda router is capable of performing 
wavelength conversion optically. A Wavelength Router is a photonic switch capable of 
mapping any wavelength on an incoming fiber to the same wavelength on any outgoing 
fiber. That is, a wavelength router is not capable of optically performing wavelength 
conversion. It should be noted that a Wavelength Router may be implemented such that 
it photonically switches groups of wavelengths (wavebands), rather than single 
wavelengths. An Optical Cross Connect (OXC) is a photonic switch capable of mapping 
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all of the wavelengths on an incoming fiber to the same outgoing fiber. That is, 
wavelengths must be switched at the granularity of a fiber. 

The following will now describe how the TMS can be used with these optically 
based devices. It can also be used with all combinations of network elements, such as 
networks containing both LSRs and Lambda Routers. In an embodiment where network 
elements are comprised mostly of optical switches, such as a Wavelength Router, path 
descriptions determined by the algorithm, are converted into mirror positions at each 
optical switch along the path. An optical switch such as a Wavelength Router directs 
wavelengths using arrays of mirrors, however the techniques described below apply to 
any optical switch regardless of the physical switching mechanism. For example, they 
also apply to devices that perform a conversion of the traffic from optical form to 
electrical form and back to optical form, called OEO switches. 

The output of the TMS Algorithm described above is a series of path descriptions. 
As described, these path descriptions can be expanded into MPLS forwarding table 
entries that associate incoming labels (Lin) on incoming interfaces (Iin) with an outgoing 
labels (Lout) on outgoing interfaces (lout). Optical Switches use connection tables that 
associate incoming wavelengths (kin) on incoming fibers (Fiberln) with outgoing 
wavelengths (tout) on outgoing fibers (FiberOut). The paths determined by the TMS 
Algorithm can be used to control optical switches by maintaining in the TMS, a table that 
associates wavelengths with labels and associates fibers with interfaces. The paths output 
by the TMS Algorithm are thereby converted into mirror positions that instantiate the 
paths. 

Each class of optical device is handled by a slightly different case: 
Case 1: Lambda Router, wavelength conversion allowed. 

Since these devices can map any (Ain,FiberIn) combination to any (tout,FiberOut) 
combination, the (Lin,Iin) and (Lout,Iout) pairs calculated by the TMS Algorithm above 
are trivially and directly converted to (Xin,FiberIn) and (Xout,FiberOut) pairs used to 
configure the device. 
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Case 2: Wavelength Router, no wavelength conversion allowed 
These devices can map a (A,,FiberIn) combination to a restricted set of 

(^FiberOut) combinations that is constrained by the architecture of the device. 

Algorithms such as RCA-1 (Chapter 6 of "Multiwavelength Optical Networks", Thomas 

E. Stern, Krishna Bala) can be used to determine paths in the absence of wavelength 

conversion. 

Case 3: OXC, no wavelength conversion allowed 

These devices can only map a (Fiberln) to a (FiberOut). Case 3 is even more 
restrictive than case 2, since there is no individual control of wavelengths, that is 
wavelengths must be switched in bundles. In this situation, an algorithm such as RCA-1 
may be used to suggest all path configurations. Afterwards, the TMS would allow only 
those path configurations where all wavelengths received on a fiber Fiberln at a switch 
are all mapped to the same outgoing fiber, FiberOut. Path decisions that would require 
individual wavelengths on the same incoming fiber to be switched to different outgoing 
fibers would be considered invalid. 

The conversion of Labels to Lambdas and Interfaces to Fibers can be performed 
by either the TMS Algorithm, or the TMS Signaling System. The installation of these 
paths into the optical switch connection tables is automated using the same methods 
described above that form the TMS Signaling System. For example, standard inter- 
process communication techniques can be used to send the network element 
configuration commands over the network via SNMP, CMIP or TL1, for example. 
Alternatively, remote serial port or remote console devices can be used to configure the 
network element. Another alternative is the use of RSVP-TE or LDP to automatically 
signal the setup of paths. 

While in this example entirely new configuration information is created for each 
time period, a more sophisticated traffic management system can compute the minimal 
set of differences between the current configuration and the desired configuration and 
transmit only these changes to the network elements. The traffic management system can 
also verify that the set of minimal configuration changes it wishes to make are made in 
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such an order as to prevent partitioning of the network or the creation of an invalid 
configuration on a network element. 

As described, the TMS creates paths suitable for use as primary paths. An 
additional concern for some carriers is the provision of protection paths for some or all of 
the traffic on their network. As part of requesting service from the carrier, some 
customers may request that alternate secondary paths through the network be pre- 
arranged to reduce the loss of data in the event any equipment along the primary path 
fails. There are many different types of protection that can be requested when setting up 
an LSP (or other type of circuit (e.g., SONET)), however the most common are (1) 
unprotected, (2) Shared N:M, (3) Dedicated 1 : 1 , and (4) Dedicated 1+1 . If the path is 
Unprotected, it means that there is no backup path for traffic being carried on the path. 
If the path has Shared protection, it means that for the N > 1 primary data-bearing 
channels, there are M disjoint backup data-bearing channels reserved to carry the traffic. 
Additionally, the protection data-bearing channel may carry low-priority pre-emptable 
traffic. If the path has Dedicated 1 : 1 protection, it means that for each primary data- 
bearing channel, there is one disjoint backup data-bearing channel reserved to carry the 
traffic. Additionally, the protection data-bearing channel may carry low-priority pre- 
emptable traffic. If the path has Dedicated 1+1 protection, it means that a disjoint backup 
data-bearing channel is reserved and dedicated for protecting the primary data-bearing 
channel. This backup data-bearing channel is not shared by any other connection, and 
traffic is duplicated and carried simultaneously over both channels. 

For unprotected traffic, no additional steps are required by the TMS. For traffic 
demands resulting from a request for service requiring protection, the TMS Algorithm 
described above and in Figure 5 is extended with the following steps. First, for a traffic 
flow requiring either 1:1 or 1+1 dedicated protection, one additional flow is placed on the 
stack in act 502, this flow having the same characteristics as the requested primary flow. 
The path that is eventually allocated for this additional flow will be used as the protection 
path for the requested flow. For traffic requiring N:M shared protection, M additional 
flows are placed on the stack in act 502, with each of the M flows having as 
characteristics the maximum of the characteristics of the requested N primary flows. 
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Second, the cost function, Cost(i,j,F), in act 506 is extended to return the value infinity if 
F is a protection path for a flow which has already been allocated a path, and that already 
allocated path involves either i or j. For Dedicated 1+1 protection paths, the TMS 
Algorithm must output to the TMS Signaling System not only the path, but also 
additional information in the common format which will cause the TMS Signaling 
System to command the ingress network element to duplicate the primary traffic onto the 
secondary protection path. For Dedicated 1 : 1 and Shared N:M paths, the TMS Algorithm 
can output to the TMS-SS additional information which will cause it to command the 
network elements to permit additional best-effort traffic onto the secondary paths. 
Hierarchical Collection and Storage of Traffic Information-Related Data 
Embodiments 

The preferred embodiments described in this section present a method and system 
of hierarchical collection and storage of traffic information-related data in a computer 
network. By way of overview, traffic information is collected from at least one network 
element at a POP using a processor at the POP. Preferably, the local processor analyzes 
the traffic information and transmits a result of the analysis to a storage device remote 
from the POP. As used herein, the phrase, "analyzing the collected traffic information" 
means more than just aggregating collected traffic information such that the result of the 
analysis is something other than the aggregation of the collected traffic information. 
Examples of such an analysis are predicting future traffic demands based on collected 
traffic information and generating statistical summaries based on collected traffic 
information. Other examples include, but are not limited to, compression (the processor 
can take groups of statistics and compress them so they take less room to store or less 
time to transmit over the network), filtering (the processor can select subsets of the 
statistics recorded by the network element for storage or transmittal to a central 
repository), unit conversion (the processor can convert statistics from one unit of 
measurement to another), summarization (the processor can summarize historical 
statistics, such as calculating means, variances, or trends), statistics synthesis (the 
processor can calculate the values for some statistics the network element does not 
measure by mathematical combination of values that it does; for example, link utilization 
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can be calculated by measuring the number of bytes that flow out a line card interface 
each second and dividing by the total number of bytes the link can transmit in a second), 
missing value calculation (if the network element is unable to provide the value of a 
statistic for some measurement period, the processor can fill in a value for the missing 
statistic by reusing the value from a previous measurement period), and scheduling (the 
processor can schedule when statistics should be collected from the network elements and 
when the resulting information should be transmitted to the remote storage). 

Preferably, the local processor in this hierarchical system acts as a condenser or 
filter so that the number of bytes required to transmit the result of the analysis is less than 
the number of bytes required to transmit the collected traffic information itself, thereby 
reducing traffic demands on the network. In the preferred embodiment, the local 
processor computes a prediction of the traffic demand for the next time period AT and 
transmits this information, along with any other of the raw or processed statistics the 
operator has expressed a request for, to the remote storage device. In an alternate 
embodiment, the local processor transmits the collected traffic information and sends it to 
the remote storage device without processing such as filtering. In other embodiments, the 
remote storage device receives additional traffic information-related data from additional 
local processors at additional POPs. In this way, the remote storage device acts as a 
centralized repository for traffic information-related data from multiple POPs. 
Additionally, the local processor at a POP can collect traffic information from more than 
one network element at the POP and can collect traffic information from one or more 
network elements at additional POPS. Further, more than one local processor can be used 
at a single POP. It should be noted that the local processor may have local storage 
available to it, in addition to the remote storage. This local storage can be used by the 
processor to temporarily store information the processor needs, such as historical 
statistics information from network elements. 

Once the data sent from the local processor at the POP is stored in the remote data 
storage device, the data can be further analyzed. For example, data stored in the storage 
device can be used as input to a hardware and/or software component that automatically 
directs data in response to the stored data, as described in the previous section. It should 
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be noted that this preferred embodiment of hierarchical collection and storage of traffic 
information-related data can be used together with or separately from the automatically- 
directing embodiments described above. 

Turning again to the drawings, Figure 6 is an illustration of one preferred 
implementation of this preferred embodiment. In this implementation, a plurality of 
POPs 600 in a computer network are coupled with a central TMS Statistics Repository 
610 (the remote data storage device). Each POP comprises a respective TMS Statistics 
Collection Server 620 (the local processor) and a respective at least one network element 
(not shown). While a TMS Statistics Collection Server is shown in Figure 6, it should be 
understood that the server can implement additional functionality. For example, as 
discussed above, the functionality of statistics collection can be combined with the 
functionality of the signaling in a single server (the TMS Collection and Signaling 
Server). In this preferred embodiment, the TMS Statistics Collection Server configures 
network elements to collect traffic information at its POPs, collects the traffic 
information, analyzes (e.g., processes, filters, compresses, and/or aggregates) the 
collected traffic information, and transmits a result of the analysis to the TMS Statistics 
Repository 610. Once the data is stored in the TMS Statistics Repository 610, it can be 
further analyzed, as described below. It should be noted that Figure 6 may represent only 
a portion of an operator's network. For example, Figure 6 could represent a single 
autonomous system (AS) or OSPF area. Data collected within this region of the network 
can be stored and processed separately from data collected in other areas. 

Preferably, the TMS Statistics Collection Servers are included at various points in 
the network to collect information from some or all of the "nearby" network elements. 
For example, a network operator can place one TMS Statistics Collection Server in each 
POP around the network, as shown in Figure 6. The exact topological configuration used 
to place the TMS Statistics Collection Servers in the network can depend upon the exact 
configuration of the network (e.g., the number of network elements at each POP, the 
bandwidth between the POPs, and the traffic load). While Figure 6 shows one TMS 
Statistics Collection Server in each POP, it is not critical that there be one TMS Statistics 
Collection Server in each POP. A network operator can, for example, choose to have one 
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TMS Statistics Collection Server per metro-area rather than one per POP. An operator 
can also choose to have multiple TMS Statistics Collection Servers within a single POP, 
such as when there are a large number of network elements within a POP. 

Network operators may prefer to place the TMS Statistics Collection Servers close 
to the network elements that they are collecting information from so that large amounts of 
information or statistics do not have to be shipped over the network, thereby wasting 
valuable bandwidth. For example, the TMS Statistics Collection Server can be connected 
to the network elements via 100 Mbps Ethernet or other high speed LAN. After the TMS 
Statistics Collection Server collects information from network elements, the TMS 
Statistics Collection Server can filter, compress, and/or aggregate the information before 
it is transferred over the network or a separate management network to a TMS Statistics 
Repository at the convenience of the network operator. Specifically, such transfers can be 
scheduled when the traffic load on the network is fairly light so that the transfer of the 
information will not impact the performance seen by users of the networks. These 
transfer times can be set manually or chosen automatically by the TMS Statistics 
Collection Server to occur at times when the measured traffic is less than the mean traffic 
level. 

Some analyses may place additional requirements on the TMS Statistics 
Collection Server. For example, when the TMS Statistics Collection Server is used to 
send traffic predictions derived from the collected traffic statistics rather than the 
statistics themselves, the TMS Statistics Collection Server may be required to locally 
store statistics for the time required to make the predictions. The TMS Statistics 
Collection Server can, for example, collect X bytes of network statistics every T seconds. 
If predictions are formed by averaging the last 10 measurements, then the TMS Statistics 
Collection Server can be equipped with enough storage so that it can store 10*X bytes of 
network information. Such a prediction would probably not result in any significant 
increase in the required processing power of the TMS Statistics Collection Server. 

As described above, the TMS Statistics Repository acts as a collection or 
aggregation point for data from the TMS Statistics Collection Servers distributed 
throughout the network. Figure 7 is an illustration of a TMS Statistics Repository 700 of 
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a preferred embodiment. As shown in Figure 7, the architecture of the TMS Statistics 
Repository 700 comprises a database 710 and a database manager 720. The database 710 
is used to store the data {e.g., statistics) received from TMS Statistics Collection Servers 
620 (or other TMS Statistics Repositories if the TMS Statistics Repositories are deployed 
in a hierarchical arrangement), and the database manager 720 provides a mechanism for 
accessing and processing the stored data. The database manager 720 and database 710 
can be implemented using any commercially available database system that can handle 
the volume of data {e.g., Oracle Database Server). Many database managers already have 
the ability to accept data over a network connection, format the data into database entries, 
and insert it into the database. If the chosen database manager does not have these 
abilities, a network server application can be constructed by any programmer skilled in 
the art of network programming and database usage to listen to a socket, receive data in 
formatted packets, reformat the data into the database entry in use, and insert the data into 
the database using the database manager. A record within the database 710 can take the 
form of a time-stamped version of the NetFlow record, as shown in Table 1 above. In the 
preferred embodiment, the record shown in Table 1 is extended with fields listing the 
predicted number of packets and predicted bandwidth required by the flow for the next 5 
AT time periods. 

Once the data is stored in the TMS Statistics Repository 610, it can be further 
analyzed. For example, the data stored in the TMS Statistics Repository 610 can be used 
as input to the TMS Algorithm 200 shown in Figure 2. It should be noted that the 
statistics collection functionality described here can be used alone or in combination with 
the embodiments described above for automatically directing data in response to traffic 
demands and with the embodiments described later in this document. If the TMS 
Algorithm or other type of automatically directing data system is used, it might be 
preferred to design the TMS Statistics Repository 610 to be fault tolerant. In this way, the 
failure of a single TMS Statistics Repository would not prevent the real-time 
provisioning. The TMS Statistics Repository can be made fault tolerant by a mechanism 
such as having the database managers replicate the database between multiple individual 
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TMS Statistics Repositories. This is a standard feature on commercially available 
database managers. 

There are several alternatives that can be used with this preferred embodiment, In 
one alternate embodiment, the TMS Statistics Collection Servers are eliminated or 
integrated with the TMS Statistics Repository so that all of the network elements ship 
monitoring information/statistics/predictions directly to a central location. 
MultipIicitv-of-ProtocoIs Embodiments 

In some networks, the network elements within a POP use different protocols. 
For example, different network elements from the same or different vendors can use 
different protocols (e.g., NetFlow, SNMP, TL1, or CMIP). Examples of protocols 
include, but are not limited to, commands or procedures for requesting data from network 
elements, commands for configuring network elements to report data, formats in which 
traffic information or statistics can be reported, or types of available data. This can 
present a compatibility problem that can prevent the local processor from collecting 
traffic information from a network element. To avoid this problem, the local processor 
used in the preferred embodiment to collect traffic information from the network 
elements is operative to collect traffic information from the network elements using their 
respective protocols. It should be noted that this functionality can be implemented alone 
or in combination with the analysis of the collected traffic information (e.g., prediction of 
future traffic demands), with the transmittal of the analyzed or raw data from the local 
processor to a remote data storage device described above, and/or with any of the other 
embodiments described herein. 

Turning again to the drawings, Figure 8 is block diagram of a TMS Statistics 
Collection Server 800 of a preferred embodiment that illustrates this functionality. As 
shown in Figure 8, the TMS Statistics Collection Server 800 comprises classification 
schema 810, network topology information 820, a plurality of protocol-specific modules 
830, and a statistics engine 840. The classification schema 810 describes the information 
that the TMS Statistics Collection Server 800 should attempt to collect from each of the 
network elements listed in the network topology information 820. For each network 
element, the relevant portion of the classification schema 810 is provided to the 
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appropriate protocol-specific module 830, which then communicates this information to 
the actual network element. The network topology information 820 allows the TMS 
Statistics Collection Server 800 to know where to go to collect the desired information. 
The network topology information 820 preferably comprises (1) a list of network 
elements from which a given TMS Statistics Collection Server should collect 
information, (2) information identifying the type of equipment (i.e., vendor and product 
ID) comprising each network element, and (3) information indicating how 
communication should take place with that network element. 

The protocol-specific modules 830 (which can be vendor-specific and/or 
equipment-specific) know how to communicate with multiple types of network devices or 
multiple instances of a network device and gather desired traffic information. The 
protocol-specific modules translate a generic request into a specific form that will be 
understood by the network element. If the network element cannot respond to the request 
directly, the protocol-specific module preferably collects information that it can get from 
the network element and tries to synthesize an answer to the request that was described 
in the classification schema 810. In one preferred embodiment, the protocol-specific 
modules 830 are responsible for (1) configuring network elements to collect network 
statistics (this can include instructing the network elements to perform filtering on the 
data that they collect so that only essential data is returned to the TMS Statistics 
Collection Server); (2) collecting network statistics for each network element; (3) filtering 
the network statistics provided by each network element (in some cases, the network 
elements themselves may be capable of filtering the data that they present to the TMS 
Statistics Collection Server so that the TMS Statistics Collection Server does not need to 
perform any filtering functions itself); and (4) converting the statistics to a common 
format understood by the overall network statistics collection system. The Statistics 
Engine 840 aggregates the network statistics received from each of the vendor-specific 
modules and then transmits them to a TMS Statistics Repository (if used) for storage and 
processing. The TMS Statistics Collection Server 800 can also perform live packet 
capture, distill this information, convert it into a common format, and then transmit it to a 
TMS Statistics Repository. 
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Because a protocol-specific module is provided for each of the protocols needed 
to retrieve statistics or other traffic information from network elements, a single TMS 
Statistics Collection Server can interoperate with multiple types of equipment from 
multiple vendors. As a result, the network elements do not need to be provided by the 
same vendor, nor do they need to be of the same type (e.g., SONET ADMs, IP routers, 
ATM switches, etc.). In this way, a single TMS Statistics Collection Server can be 
enabled with the appropriate protocol modules that will allow it to simultaneously collect 
information from many varied network elements. For example, the TMS Statistics 
Collection Server can, using three separate protocol modules, process NetFlow data from 
a Cisco Router, process SNMP statistics from an ATM switch, and process CMIP 
statistics from a SONET ADM. 

Each of these modules can also contain sub-modules that allow the TMS 
Statistics Collection Server to communicate with different types of network elements. 
Such a set of sub-modules is shown in Figure 11. For example, if a single TMS Statistics 
Collection Server needs to communicate with both Vendor A's router and Vendor A's 
optical cross-connects, the vendor-module for Vendor A can include two sub-modules: 
one to interact with the router and another to interact with the cross-connect. In the event 
that both the router and the optical cross-connect support the same external interface to 
the TMS Statistics Collection Server, a single sub-module can be used to interact with 
both devices. 

To the TMS, different types of network elements are distinguished by the 
protocols by which they are configured, the protocols by which they communicate, and 
the features that they provide. If two vendors each produce a different network element, 
but those network elements use the same protocols for configuration and communication 
and provide the same features, the TMS can treat them in the same fashion (although in 
certain cases, even use of the same protocol will require the TMS Signaling System use a 
different module to communicate with the network elements). However, if the same 
vendor produced two different network elements, each of which used a different protocol, 
the TMS would treat those two elements differently, even though they were produced by 
the same vendor. 
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The list of network elements and a mechanism for addressing/communicating 
with these network elements may be manually configured into the TMS Statistics 
Collection Server by the network operator, or it may be discovered by the TMS Statistics 
Collection Server if the carrier is running one or more topology discovery protocols. An 
example of a suitable topology discovery protocol is the Traffic Engineering extensions to 
the Open Shortest Path First (OSPF) routing protocol (OSPF-TE). Once the TMS 
Statistics Collection Server has a complete list of the network elements and a method for 
addressing them, it can then query each device (via SNMP, for example) to determine the 
type of device, the vendor, etc. This information can also be manually configured into the 
network topology information module. 

There are several alternatives that can be implemented. For example, the TMS 
Statistics Collection Server can be eliminated, and a central source can query each device. 
Additionally, a TMS Statistics Collection Server can be required for each vendor (i.e., 
only one vendor-specific module per TMS Statistics Collection Server). Further, a TMS 
Statistics Collection Server can be required for each supported protocol (i.e., only one 
protocol-specific module per TMS Statistics 'Collection Server). 

The following is an example illustrating the operation of the TMS Statistics 
Collection Server of this preferred embodiment. For this example, the topology 
information has been manually configured to list one IP router, Rl, with an IP address of 
1.1.1.1. The following is an example of information that can comprise a classification 
schema for an IP router (Rl). The schema need not contain all of these fields or can 
contain many other fields. The example classification schema for router Rl consists of 
the following field(s): 

1. Network Element ID 

- An identifier (perhaps serial number) that uniquely identifies Rl 

2. Network Element Address Information 

- IP Address of Rl. This can also, for example, identify a particular 
ATM PVC/SVC used to communicate with Rl 

3. Network Equipment Vendor ID 
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- ID indicating which vendor-specific module should interact with Rl 
As a result of processing the classification schema for Rl, the TMS Statistics 
Collection Server sends one or more directives/rules to router Rl . Each directive is 
preferably comprised of an Information Request Record and an IP Flow Description 
Record. The IP Flow Description Record can also be combined with one or more 
transport-layer flow description records, for example, a TCP flow description record or a 
UDP flow description record. 

• Information Request Record: 

1 . Packet receive count 

2. Packet forward count 

3. Data rate (e.g, . estimate of bits/second over some interval Tl) 

4. Max burst size {e.g., max number of packets observed over some interval 
T2) 

• IP Flow Description Record: 

1 . Incoming Interface Index {e.g. , SNMP Index) 

2. Outgoing Interface Index (e.g. 5 SNMP Index) 

3. Incoming Label {e.g., MPLS label used on incoming interface) 
Outgoing Label {e.g., MPLS label used on outgoing interface) 

OR 

4. IP Source Address 

IP Source Address Mask 

IP Destination Address 

IP Destination Address Mask 

IP Type of Service {i.e., TOS or DIFFSERV bits) 

IP Protocol {i.e., transport-layer protocol) 

OR 

5. Source Administrative System 
Destination Administrative System 
Ingress point 

An IP flow record preferably consist of only 3, 4, or 5 , however, any combination 
can be specified. 

• TCP Flow Description Record: 

TCP Source Port 
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TCP Destination Port 

• UDP Flow Description Record: 
UDP Source Port 
UDP Destination Port 

The classification schema can also include additional information useful to the 
TMS Statistics Collection Server. Examples of such information include the mapping of 
IP addresses to Autonomous System numbers, which is used in processing the traffic 
statistics to condense the statistics or to answer a classification schema including requests 
for IP Flow DescriptionRecords of type 5. 
Network Reconfiguration Embodiments 

Turning again to the drawings, Figure 9 shows the components of a TMS 
Signaling System 900 of a preferred embodiment. As shown in Figure 9, this preferred 
TMS Signaling System 900 comprises a reconfiguration module 910, a state transition 
checker 920, and a signaling distribution module 930. In operation, the reconfiguration 
module 910 creates a series of network transformation instructions. As used herein, the 
term "network transformation instruction" is intended broadly to refer to any instruction 
that can be used to configure or reconfigure one or more network elements in a computer 
network to create a network configuration. Examples of network transformation 
instructions include, but are not limited to, instructions to establish a link, circuit, or path 
between nodes and instructions to tear down a link, circuit, or path. 

In Figure 9, the reconfiguration module 910 combines the network topology 
information 940 with the output of the TMS Algorithm 950 to create a configuration for 
each of the network elements represented in the network topology. This topology is 
described in a common format used by the system. The configuration is preferably not 
converted to equipment/vendor-specific configurations until after the configuration is 
processed by the state transition checker 920. An acceptable common format for the 
system is the complete set of Command Language Interface (CLI) commands defined by 
a common router vendor, such as the Cisco CLI. The network topology can be 
determined by any number of methods. For example, the network operator can run a 
routing protocol such as OSPF or ISIS (possibly with Traffic Engineering (TE) 
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extensions). The network operator can also assemble the configured files for each of the 
IP routers in the network and using the information contained therein to construct a graph 
of the network topology. 

The state transition checker 920 determines whether the series of network 
transformation instructions is valid (e.g., that the state transitions induced by a network 
configuration or reconfiguration do not result in intermediate states that prevent later 
states from being reached). In this way, the state transition checker 920 acts as a "sanity 
check" to make sure that everything happens in an orderly fashion. When reviewing a 
network configuration, the state transition checker 920 ensures that the order in which 
network elements are configured does not create undesirable intermediate states in the 
network. For example, when reconfiguring an optical cross-connect, it might be possible 
to partition a portion of the network from the TMS Signaling System 900 if network 
element configurations are executed in the wrong order. The state transition checker 920 
orders the configuration steps to ensure that the network configuration can be 
implemented completely and without destabilizing the network. The state transition 
checker 920 can be implemented as a network simulator that establishes an ordering for 
the network element re/configuration instructions and then simulates the behavior of each 
of these instructions to ensure correctness and stability. The initial ordering for the 
reconfiguration instructions is the order that results from the execution of the TMS 
algorithm as described above. If this ordering is found to cause incorrectness or 
instability, the order is permuted so that the failing step is placed first. Several iterations 
of this method will typically result in an acceptable order. Examples of suitable network 
simulators include the NetMaker product from Make Systems and the simulator described 
in "IP Network Configuration for Traffic Engineering" by Anja Feldman and Jennifer 
Rexford, ATT TR-000526-02, May 2000, which is hereby incorporated by reference. 

When the state transition checker 920 verifies a valid series of instruction, the 
instructions are sent to the signaling distribution module 930. The signaling distribution 
module 930 is responsible for ensuring that each of the network elements is properly 
configured. In operation, the distribution module 930 distributes the configuration 
information to the local TMS Signaling Servers in the order determined by the state- 
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transition checker 920. If the signaling distribution module 930 communicates directly 
with each of the network elements, the protocol-specific modules described above can be 
implemented to convert the description of the configuration produced by the 
reconfiguration module 910 into specific instructions that are understood by each of the 
network elements. Alternatively and preferably, the signaling distribution system 930 can 
send the configuration for each network element to the appropriate TMS Signaling 
Server, such as the TMS Signaling Server 1000 shown in Figure 10. The protocol- 
specific modules 1010 on the TMS Signaling Server 1000 can then convert the generic 
configuration information into the appropriate commands that are understood by each 
network element. 

Carriers may wish to offer levels of preferential service having a specific SLA to 
customers willing to pay a premium. This preferential service is delivered by 
provisioning private paths in the network. Every path calculated by the TMS Algorithm 
in response to a request for service constitutes a private path, as the TMS Algorithm will 
arrange the traffic in the network such that any constraints expressed by the request are 
satisfied. Examples of constraints include bandwidth, latency, packet loss rate, and 
scheduling policy. A Virtual Private Network is a specific type of a private path. 

Appendix I and Appendix II contain text of Matlab code. This code can be run on 
any computer capable of supporting the Matlab package sold by The Mathworks, Inc. 
The preferred computer is a high-end Intel-based PC running the Linux operating system 
with a CPU speed greater than 800 MHz. Conversion of the code from Matlab M-Files to 
C code can be achieved via the use of The Mathworks M-File to C compiler. Such a 
conversion may be desirable to reduce the running time of the code. The code shown in 
Appendix I provides a presently preferred implementation of the TMS Algorithm, the 
creation and use of network topology information, the use of traffic demand retrieved 
from predictions in the TMS Statistics Repository, and the creation of path specifications 
that serve as input to the TMS Signaling System. The code shown in Appendix II 
provides a presently preferred implementation of the network topology information 
creation. In the preferred embodiment, the TMS Signaling System runs on the same 
hardware that implements the TMS Algorithm. The Network Policy Information and 
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Network Topology Information can be entered or discovered by processes running on the 
same hardware as the TMS Algorithm, or on a separate management console computer. 
The management console computer is preferably a high-end PC workstation with a large 
monitor running the linux operating system. 

The preferred embodiment of the TMS Statistics Collection Server is a 
commercially-available rack-mountable computer having: an Intel Pentium Processor 
with a CPU clock speed of 1 GHz or greater, linux or FreeBSD operating system, 20 GB 
or more local disk space, and at least one 100 Mbps Ethernet port. 

The preferred embodiment of the TMS Statistics Repository is an UltraSPARC 
server as manufactured by Sun Microsystems with a RAID storage subsystem managed 
by Oracle Database Server. 

It is intended that the foregoing detailed description be understood as an 
illustration of selected forms that the invention can take and not as a definition of the 
invention. It is only the following claims, including all equivalents, that are intended to 
define the scope of this invention. 
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APPENDIX I 



% Creating a network topology obj 

networkjopo = topo('init'); 
addlink(network_topo); 
labelnames(network_topo) ; 

save networkjopo; 



% graphically place nodes on screen 
% graphically connect up nodes 
% graphically label nodes 

% save network_topo for future use 



% Top level procedure to compute paths that optimize use of network capacity 
% inputs: 

% D = traffic demand matrix 

% (retrieved from predictions stored in TMS Statistics Repository) 
% networkjopo = topology object defining the network topology 
% P = network policy information 

% (matrix of reserved capacity, which indicates links whose use 

% is administratively prohibited or which should not be 

% completely allocated) 

% outputs: 

% allocated_paths() - list of paths to set up, to TMS signalling system 



C - capacity(networkjopo); % retrieve network topology information 

C = C - P; 

saved_C = []; 
saved_SLA= []; 
assigned_paths = []; 
round = 0; 

[SLA, S] = create_ordered_sla(D); 
F = SLA(1) 

for F - SLA', 

round == round +1; 
saved__C {round} = C; 
saved_SLA{round} = F; 

F % display the flow 

W = calc_weights( , calcweight2 , ,F,C); 
[dist, P] = floyd(W); 
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path = fmdpath(P,F.i,F j); 

assigned_paths {round} .path = path; 
5 assigned jpaths {round} .flow = F; 

if (isempty(path)) 

fprintf(l ? 'no path for flow:W); F 

else 

10 C = compute_residual_capacity('c - F.bw',path,F,C); 

end 

end 

1 5 function [W] = calc_weights(func,F,C) 

% function [W] = calcjweights(func,F,C) 
% 

% Compute the weights by calling func on each elt of C 

% fane must be of the form double func(Flow F, Capacity_elt c, node i, node j) 

If 

y func = fcnchk(func); 

H for i= l:size(C,l) 

i"U for j = l:size(C,2) 

1 W(i j) = feval(func,F,C(i j),i j); 

m function [w] = calcweight2(F ? c ? i j) 

S§ % function [w] = calcweight2(F,c ; i j) 

H % basic weight calc 

if (0 = c) 

w = inf; 
35 return; 
end 



% rule out paths that can't hack it 
40 if (F.bw>c) 

w = inf; 
return; 

end 
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w = 1 / (c - F.bw) ; % fill links with most capacity first 

function [C] = compute_residual_capacity(func, path, F, C) 
% function [C] = compute_residual_capacity(func 5 path, F, C) 
% 

% Update capacity characteristics in C to reflect flow F being 

% allocated along path using function func 

% func should be of the form 

% C_element func(C_element c, Flow F) 

if(length(path) <= 1) 
return; 

end 

func = fcnchk(func,'cVF'); 

index = 1 ; 

src = path(index); 

index = index + 1 ; 

for index = index :length(path) 
dst = path(index); 

C(src,dst) = feval(func,C(src,dst),F); 
src = dst; 

end 

function [SLA, S] = create_ordered_sla(D) 

% function [SLA] = create_ordered_sla(D) 

% takes the demand matrix and returns a list of SLAs, 

% SLA of the form [ struct ; struct ; ... ] where struct is [BW, 

% S of the form [ [BW, i, j] ; [BW, i, j] ; ...] 



s = D; 

for i = l:size(D,l) 

for j = l:size(D,2) 

if(D(i,j)~=0) 

S = [[D(ij)ij];S]; 

end 

end 

end 
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[Y, I] = sortrows(S,l); 

S = Y(size(Y,l):-l:l,:); % reverse order 

SLA = struct(W,num2cell(S(:, l));i',num2cell(S(:,2)) s , j , ,num2cell(S(:,3))); 
return; 

function [path] = findpath(P,i,j) 
% function [path] = findpath(P) 

% 
% 

path=[]; 

if(i==j) 

path = [i]; 

return; 

end 

if(0 = P(ij)) 

path=[]; 

else 

path=[findpath(P,i,P(i,j))j]; 

end 

function [D, P] = fioyd(W) 
% function [D, P] = floyd(W) 

% given weights Wij, compute min dist Dij between node i to j 
% on shortest path from i to j, j has immeadiate predecessor Pij 

n = size(W,l); 
if(n~= size(W,2)) 

error('Input W is not square??! !'); 

end 

D = W; 

P = repmat([l:n]',[l n]); 
P = P * ~isinf(W); 
P = P .* ~eye(n); 

for k = 1 :n 

for i = 1 :n 
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for j = l:n 

alt_path = D(i,k) + D(k j); 
if(D(i,j)>alt_path) 

D(i,j) = alt_path; 

P(ij) = P(k,j); 

end 

end 
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APPENDIX II 

function addlink(TOPO) 
% addlink(TOPO) 

% 

% interactively add links to the TOPO 

update(TOPO); 
c_src = 1 ; 
c_dst = 2; 
c_bw = 3; 

figure(TOPO.cur_fig) 
while (1) 

fprintf(l,'\n\nHit Button 3 to end...\n\n'); 

% find coords and index i of src 
[xli yli button] = ginput(l); 
if (button == 3) break; end 

d = sqrt((TOP0.1ocs(:,l) - xli) A 2 + (TOP0.1ocs(:,2) - yli). A 2); 
[d,i] = min(d); 

xl = TOPO.locs(U); yl = TOP0.1ocs(i,2); 

% find coords and index j of dst 
[x2i y2i] = ginput(l); 

d = sqrt((TOP0.1ocs(:,l) - x2i) A 2 + (TOP0.1ocs(:,2) - y2i) A 2); 
[d,j] = min(d); 

x2 = TOP0.1ocsG,l); y2 = TOP0.1ocs(j,2); 
hold on; 

lh = line([xl x2],[yl y2],'color7red'); 
cap = input('Enter capacity (in Mbps) > '); 

fprintf(l, 'About to create symetric %d Mbps link from node %d to node %d\n',cap,ij); 

doit = input('Enter Y to confirm, N to reject, and B to change bandwidth (Y)> ','s'); 

if (isempty(doit)) doit = 'Y'; end 

if (doit == 'n'ldoit^'N') 
delete(lh); 
return; 
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end 

if (doit = V | doit = 'B f ) 

buf = sprintf( T Enter capacity from %d to %d (in Mbps) > ',i j); 
cap_i_to J = input(buf); 

buf = sprintf('Enter capacity from %d to %d (in Mbps) > \j,i); 
cap J_to J = input(buf); 

else 

cap_i_toJ = cap; 
capj __to_i = cap; 

end 

%build the link records 
clear linkab linkba; 

linkab.src = i; 
linkab.dst = j; 
linkab.bw = cap_i__toJ; 
linkab.handle = lh; 

linkba. src = j; 
linkba.dst = i; 
linkba.bw = cap J_to_i; 
linkba.handle = lh; 



% now draw the actual link on the map 
delete(lh); 

lh = drawlink(TOPO, linkab); 

% now store the link info 

TOPO.links = [TOPO.links ; linkab ; linkba ]; 

TOPO.linkarray - [TOPO.linkarray ; [ i j capjjoj] ; [ j i cap j_to_ 

end % of while loop 
assignin( f caller , ? inputname(l) ? TOPO); 



function [C, portmap] = capacity(TOPO) 
% [C 5 portmap] = capacity(TOPO) 
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% portmap maps indices of C to elts of nodes(TOPO) 
% [node dir] where 

% node is index of elt in nodes(TOPO) 

% dir is 1 if data enters here, -1 if data leaves here 

5 

numnodes = length(TOPO.links) * 2; 

C = zeros(numnodes,numnodes); 

10 curnode = 0; 

portmap = []; 

for i = l:length(TOP0.1inks) 
link = TOPO.links(i); 
curnode = curnode + 1; 
1 5 portmap(curnode, :) = [link.src - 1 ] ; 

curnode = curnode + 1 ; 
portmap(curnode,:) = [link.dst 1]; 

;i C(curnode- 1 ,curnode) = link.bw; 

|| end 

yk c_node = 1 ; 

H cjiir = 2; 

15 for i = 1 :length(TOPO.nodes) 

;L, ins = find(portmap(: ? c_node) == i & portmap(:,c_dir) == 1); 

outs = fmd(portmap(:,c_node) = i & portmap(:,c_dir) = -1); 

ffl for j= ins 

S|) for k = outs 

H C(j,k) = inf; 

end 

end 

end 

35 function [a, b, c] = debug(t) 

update(t); 
fieldnames(t) 

40 

a = t.nodes 
b = t.locs 
c = t links 

function display(TOPO) 
45 % DISPLAY a topo object 
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% a link is a unidirectional, so the value is probably twice what you want 

fprintfQTOPO object: %d nodes %d links]\n',... 

length(TOPO.nodes),length(TOP0.1inks)); 
function draw(TOPO) 
% draw(topo) 
% 

% draw the topology figure in a new window 

TOPO.curJig = figure; 

axis(TOPO.axis); 

axis equal; 

axis manual; 

box on; 

hold on; 

for i - 1 :length(TOPO.nodes) 

nm = plot(TOPO.nodes{i}.loc(l) ; TOPO.nodes{i}.loc(2), , ob , ); 
TOPO. nodes {i}.mark_handle = nm; 
if(isfield(TOPO.nodes{i};nameloc')) 

TOPO.nodes{i}.nameloc(3) = text(TOPO.nodes{i}.nameloc(l) v 
TOPO.nodes{i}.nameloc(2) ? TOPO.nodes{i}.name 

end 

end 

% yes, this draws the same link twice, fix it if it matters -dam 11/21 

TOP0.1inkarray = []; 

for i = 1 :length(TOP0.1inks) 

TOP0.1inks(i).handle = drawlink(TOPO ? TOP0.1inks(i)); 

TOPO.linkarray = [TOPO.linkarray ; ... 

[ TOPO,links(i).src TOP0.1inks(i).dst TOP0.1inks(i).bw]]; 

end 

assignin('caller , ? inputname(l) ? TOPO); 
function ex(t) 

t.nodes 

function labelnames(TOPO) 
% function labelnames(TOPO) 
% make it easy to label the nodes 

for i = 1 :length(TOPO.nodes) 

fprintf('Place label for node %d M %s M \n , ,i ? char(TOPO.nodes{i}.name)); 
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origcolor = get(TOPO.nodes{i}.mark_handle;color f ); 
set(TOPO.nodes{i}.mark_handle;color f ? [l 0 0]); 

if(isfield(TOPO.nodes{i} 5 , nameloc r )) 

good_x = TOPO.nodes{i}.nameloc(l); 
good_y = TOPO.nodes{i}.nameloc(2); 

end 

th = D; 

while (1) 

fprintf('Button 1 to (re)place text, Button 3 to acceptW); 

[x ? y ? button] = ginput(l); 

if (3 = button) break; end 

if (-isempty(th)) delete(th); end 

th = text(x,y,TOPO.nodes{i}.name); 

good_x = x; goodly = y; 

end 

TOPO.nodes{i}.nameloc = [good_x, good_j, th]; 
set(TOPO.nodes{i}.mark__handle ? , color , ? origcoior); 

end 

assigninCcaller^inputnameCl ),TOPO);function names(TOPO) 
% NAMES the list of names of the nodes in the topo 

fprintf('Node\t\tNameW); 
for i - 1 :size(TOPO.names,l) 

fprintfCyodW/osW^JOPO.namesli}); 

end 

function [node] = nodes(TOPO) 

% function [node] - nodes(TOPO) 

% returns a cell array describing nodes in the TOPO 

node = TOPO.nodes; 

function [TOPO] =topo(TOPO) 

%[TOPO]-topo(TOPO) 

%% if input TOPO is 'init', create a new topology 

% 

% newtopo = topoCinit') ; 

% 

% else add new nodes to TOPO 

% 

% nodes is a array of structs, one per node 

% link is a array of structs, one per link 

% a link is a unidirectional item, so there are probably twice 

% as many links as you'd expect. 
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if (nargin < 1) 

errorCtopo(TOPO) or topofinif ) - not enough args') 

end 

if (ischar(TOPO) & TOPO = 'inif) 
clear TOPO 

TOPO.nodes - []; 
TOP0.1inks = []; 

TOPO.capacity = []; % now computed as needed 
TOPO.locs = []; % internal cache 
TOPO.linkarray = []; % internal cache 

f = figure; 
axis([0 75 0 50 ]); 
TOPO. axis = axis; 
TOPO.curJig - f; 
axis equal 
axis manual 
box on 
hold 

else 

figure(TOPO.curJIg); 

end 



nodecount = length(TOPO.nodes); 

while (1) 

clear nodeinfo; 

fprintf(l/\n\nHit Button 3 to stop\n\n'); 

[xybut] = ginput(l); 

if (but == 3) break; end 

x = floor(x); y - floor(y); 

nm = plot(x,y ? 'ob'); 

name = input('Enter name > 7s ! ); 

nodeinfo.loc = [xy]; 
nodeinfo. mark_handle = nm; 
nodeinfo.name = cellstr(name); 
nodecount = nodecount + 1 ; 
TOPO.nodes {nodecount} = nodeinfo; 

end 
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if Ctopo' ~= class(TOPO)) 

TOPO = class(TOPO,'topo'); 

end 

5 

if (nargout == 0) 

assignin('caller',inputname( 1 ),TOPO) ; 

end 

function lh = drawlink(TOPO, link) 
10 % assumes TOPO.linkarray is already valid, and draws the position of 

% link line based on the number of links already present in linkarray 
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c_src = 1 
c_dst = 2 
c bw = 3 
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i = link.src; 
j = link.dst; 

xl =TOPO.nodes{i}.loc(l) 
yl =TOPO.nodes{i}.loc(2) 
x2 = TOPO.nodes{j}.loc(l) 
y2 = TOPO.nodes{j}.loc(2) 
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if (isempty(TOPO.linkarray)) 
num_links = 0; 

else 

numjinks = sum(TOP0.1inkairay(:,c_src) = i & TOP0.1inkarray(:,c_dst) == j); 

end 

pattern = [0 1-12-2 3-3]*.3; 

if(abs(xl -x2)>abs(yl -y2)) 
deltax = 0; 

delta_y = pattern(num_links +1); 

else 

delta_x = pattern(num_links +1); 
delta_y = 0; 

end 

lh = line([xl x2] + delta_x, [yl y2] + delta_y, 'color*, 'black'); 
function update(TOPO) 
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clear TOPO.locs; 

for i = l;length(TOPO.nodes) 

TOP0.1ocs(i,:) = TOPO.nodes{i}.loc 

end 

clear TOPO.linkarray; 

for i = 1 :length(TOP0.1inks) 

TOPO.linkarray - [TOPO.linkarray ; ... 

[ TOP0.1inks(i).src TOP0.1inks(i).dst TOP0.1inks(i).bw]]; 

end 

% these are here to be cut and pasted into other functions as needed 

% there doesn't seem to be a good way to pass them around in another fashion 

% (using assigningCcaller 1 ...) to force their definition sounds like asking 

% for trouble 'cause you'll overwrite another definition of them...) 

c_src = 1 ; 

c_dst = 2; 

cbw = 3; 

assignin('caller'4nputname(l),TOPO); 



